<template>
  <XtxDialog
    :title="(id ? '修改' : '添加') + '收货地址'"
    v-model:visible="dialogVisible"
  >
    <div class="address-edit">
      <div class="xtx-form">
        <div class="xtx-form-item">
          <div class="label">收货人：</div>
          <div class="field">
            <input
              v-model="receiver"
              class="input"
              placeholder="请输入收货人"
            />
          </div>
        </div>
        <div class="xtx-form-item">
          <div class="label">手机号：</div>
          <div class="field">
            <input v-model="contact" class="input" placeholder="请输入手机号" />
          </div>
        </div>
        <div class="xtx-form-item">
          <div class="label">地区：</div>
          <div class="field">
            <XtxCity
              @change="changeCity"
              :fullLocation="fullLocation"
              placeholder="请选择所在地区"
            />
          </div>
        </div>
        <div class="xtx-form-item">
          <div class="label">详细地址：</div>
          <div class="field">
            <input
              v-model="address"
              class="input"
              placeholder="请输入详细地址"
            />
          </div>
        </div>
        <div class="xtx-form-item">
          <div class="label">邮政编码：</div>
          <div class="field">
            <input
              v-model="postalCode"
              class="input"
              placeholder="请输入邮政编码"
            />
          </div>
        </div>
        <div class="xtx-form-item">
          <div class="label">地址标签：</div>
          <div class="field">
            <input
              v-model="addressTags"
              class="input"
              placeholder="请输入地址标签，逗号分隔"
            />
          </div>
        </div>
      </div>
    </div>
    <template v-slot:footer>
      <XtxButton
        @click="dialogVisible = false"
        type="gray"
        style="margin-right: 20px"
        >取消</XtxButton
      >
      <XtxButton @click="submit" type="primary">确认</XtxButton>
    </template>
  </XtxDialog>
</template>
<script>
import { reactive, ref } from "vue";
import { toRefs } from "@vueuse/core";
import { addAddress, editAddress } from "@/api/order";
import Message from "@/components/library/Message";
export default {
  name: "AddressEdit",
  setup(props, { emit }) {
    const dialogVisible = ref(false);
    // 打开确认框函数
    const open = (address) => {
      dialogVisible.value = true;
      // 有id修改数据
      if (address.id) {
        for (const key in formData) {
          formData[key] = address[key];
        }
      } else {
        // 无id添加数据，每次打开清空表单数据
        for (const key in formData) {
          if (key === "isDefault") formData[key] === 0;
          formData[key] = "";
        }
      }
    };

    // 表单数据
    const formData = reactive({
      id: "",
      receiver: "",
      contact: "",
      provinceCode: "",
      cityCode: "",
      countyCode: "",
      address: "",
      postalCode: "",
      addressTags: "",
      isDefault: 0,
      fullLocation: "",
    });

    // 选择地区
    const changeCity = (data) => {
      formData.provinceCode = data.provinceCode;
      formData.cityCode = data.cityCode;
      formData.countyCode = data.countyCode;
      formData.fullLocation = data.fullLocation;
    };
    // 提交操作
    const submit = () => {
      if (formData.id) {
        editAddress(formData).then((data) => {
          // 修改成功
          Message({ text: "修改收货地址成功", type: "success" });
          dialogVisible.value = false;
          emit("on-success", formData);
        });
      } else {
        addAddress(formData)
          .then((data) => {
            //   添加成功
            formData.id = data.result.id;
            Message({ type: "success", text: "添加收货地址成功" });
            dialogVisible.value = false;
            emit("on-success", formData);
          })
          .catch((res) => {
            if (res.status === 500) {
              Message({ type: "error", text: res.message });
            }
          });
      }
    };
    return { dialogVisible, open, changeCity, ...toRefs(formData), submit };
  },
};
</script>
<style scoped lang="less">
.address-edit {
  .xtx-dialog {
    :deep(.wrapper) {
      width: 780px;
      .body {
        font-size: 14px;
      }
    }
  }
  .xtx-form {
    padding: 0;
    input {
      outline: none;
      &::placeholder {
        color: #ccc;
      }
    }
  }
  .xtx-city {
    width: 320px;
    :deep(.select) {
      height: 50px;
      line-height: 48px;
      display: flex;
      padding: 0 10px;
      justify-content: space-between;
      .placeholder {
        color: #ccc;
      }
      i {
        color: #ccc;
        font-size: 18px;
      }
      .value {
        font-size: 14px;
      }
    }
    :deep(.option) {
      top: 49px;
    }
  }
}
</style>